



Figure 1: Schema di datapath

Rispondere alle domande a risposta multipla annerendo la casella corrispondente alla risposta corretta. Ogni domanda ha una ed una sola risposta corretta.

|   | Cognome e Nome:                                                                                                                                                                                                                        |
|---|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|   | Matricola:                                                                                                                                                                                                                             |
| Γ | Oomanda 1 Con riferimento alla figura 1, si dica quale delle seguenti affermazioni è corretta.                                                                                                                                         |
|   | Il blocco addizionatore in alto a destra è usato per implementare i salti condizionati. Il blocco shift a sinistra di due che lo precede è necessario per trasformare l'indirizzo del salto da offset relativo a valore assoluto.      |
|   | Il blocco addizionatore in alto a destra viene utilizzato per calcolare l'indirizzo da cui prelevare un dato richiesto per un'operazione di lw.                                                                                        |
|   | Il blocco addizionatore in alto a destra è usato per implementare i salti condizionati. Il blocco shift a sinistra di due che lo precede è necessario per trasformare l'indicazione dell'indirizzo da word a byte.                     |
|   | Nessuna delle altre risposte                                                                                                                                                                                                           |
| _ | <b>Domanda 2</b> Si consideri una fully associative grande $16KB$ , con blocchi di 64 byte per blocco. In che blocco di cache è mappata la parola che sta all'indirizzo $0x100620$ ?                                                   |
|   | Nel blocco numero 48 o nel blocco numero 49.                                                                                                                                                                                           |
|   | Nel blocco numero 24.  Le cache fully associative hanno il tag memorizzato per intero e non utilizzano gli ultimi bit per decidere la posizione Nel blocco numero 0 o nel blocco numero 1 o nel blocco numero 2 o nel blocco numero 3. |
|   | Nessuna delle altre risposte.                                                                                                                                                                                                          |
|   | Nel blocco numero 32.                                                                                                                                                                                                                  |



| Domanda 8 L'istruzione lea (%rdi, %rsi), %rax:                                                                                                                                                                         |
|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Carica in %rax il contenuto della locazione di memoria indicata da %rdi + %rsi                                                                                                                                         |
| Nessuna delle altre risposte                                                                                                                                                                                           |
| Somma il contenuto dei registri %rdi ed %rsi salvando il risultato in %rax                                                                                                                                             |
| Non è un'istruzione Assembly valida                                                                                                                                                                                    |
| Salva il contenuto di %rax nella locazione di memoria indicata da %rdi + %rsi                                                                                                                                          |
| <b>Domanda 9</b> Si consideri una CPU in cui le 5 fasi di esecuzione di un'istruzione impiegano $100ps,\ 400ps,\ 600ps,\ 300ps$ e $100ps$ . L'incremento di prestazioni che ci si può attendere usando una pipeline è: |
| di 2 volte                                                                                                                                                                                                             |
| di 3 volte                                                                                                                                                                                                             |
| Nessuna delle altre risposte                                                                                                                                                                                           |
| $\square$ di $3.5$ volte                                                                                                                                                                                               |
| di 2.5 volte                                                                                                                                                                                                           |
| <b>Domanda 10</b> Si consideri la seguente istruzione: movb (%rsi, %rax), %bl . Si dica quale delle seguenti alternative è vera:                                                                                       |
| E' un'istruzione ARM sbagliata sintatticamente                                                                                                                                                                         |
| Nessuna delle altre risposte                                                                                                                                                                                           |
| E' un'istruzione MIPS sbagliata sintatticamente                                                                                                                                                                        |
| $\hfill \hfill \hfill$ E' un'istruzione INTEL che sposta un byte dall'indirizzo di memoria puntato da %rsi $+$ %rax nel sotto-registro %bl                                                                             |
| $\hfill \hfill \hfill$ E' un'istruzione INTEL che sposta nel registro %<br>bl la word a 64bit puntata da %rsi+%rax                                                                                                     |
| Domanda 11 Nell'architettura MIPS, un gestore di eccezione: Non l'abbiamo fatto :                                                                                                                                      |
| E' pre-programmato in un "coprocessore" e non può essere modificato dall'utente.                                                                                                                                       |
| Nessuna delle altre risposte                                                                                                                                                                                           |
| ☐ Viene eseguito dalla CPU solo dopo che tutte le fasi di polling sono terminate.                                                                                                                                      |
| Può leggere in registri speciali (Cause, EPC ed altri) il motivo dell'eccezione, l'indirizzo della prossima istruzione da fetchare dopo aver gestito l'eccezione, etc                                                  |
| Non è in grado di capire la causa di un'eccezione.                                                                                                                                                                     |
| Domanda 12 I quattro bit di controllo della ALU sono generati da:                                                                                                                                                      |
| $\  \  \  \  \  \  \  \  \  \  \  \  \  $                                                                                                                                                                              |
| un'unità di controllo che riceve in ingresso il campo funct prelevato dall'istruzione                                                                                                                                  |
| $\square$ un'unità di controllo che riceve in ingresso i campi $funct$ e $shamt$ prelevati dall'istruzione e i due bit detti ALUop                                                                                     |
| Nessuna delle altre risposte                                                                                                                                                                                           |
| un'unità di controllo che riceve in ingresso i due bit detti ALUop                                                                                                                                                     |

Questa è quella più lunga, quindi dovrebbe essere giusta

+10/4/21+